草庐IT

C++ unique_ptr 和映射

全部标签

c++ - 如何存储由 std::unique_ptr 给出的抽象类对象的 vector ?

我有一个循环,在这个循环中我使用一个函数将std::unique_ptr返回给一个抽象类的对象。我想通过push_back将这些对象存储到std::vector中。但由于对象是抽象类型,我得到以下错误:error:cannotallocateanobjectofabstracttype为线cells.push_back(std::move(*cell));其中cells是抽象类型的std::vector而cell是类型std::unique_ptr&&cell(我实际上将cell传递给处理程序类)我知道不能实例化抽象类型,而且我正在理解std:move运算符,它需要以某种方式实例化对象

c++ - 在 shared_ptr 容器中查找元素?

我在查找shared_ptrvector中的元素时遇到了一点问题。这是我最终得到的结果:std::vector>blocks;boolcontains(Block*block){for(autoi=blocks.begin();i!=blocks.end();++i){if((*i).get()==block){returntrue;}}returnfalse;}但是,我没能用std::find甚至std::find_if做到这一点。是否有更符合C++标准的方法来实现这一目标?编辑:这是我在回答之后的代码:boolcontains(Block*block){autofound=std:

c++ - 使用 std::unique_ptr 的具有私有(private)析构函数的单例

我在我的程序中创建了所有单例,并牢记该文档:http://erdani.com/publications/DDJ_Jul_Aug_2004_revised.pdf(如果有人想知道为什么单例,它们都是工厂,其中一些存储一些关于它们应该如何创建实例的全局设置)。他们每个人看起来都像这样:声明:classSingletonAndFactory{staticSingletonAndFactory*volatileinstance;public:staticSingletonAndFactory&getInstance();private:SingletonAndFactory();Single

c++ - shared_ptr 析构函数、复制和不完整类型

我有一个头文件foo.h像这样(省略不相关的东西):#pragmaonce#includeclassBar;structFoo{std::shared_ptrgetBar();std::shared_ptrgetBar()const{returnconst_cast(this)->getBar();}};getBar()的非常量重载在.cpp文件中实现,该文件还可以看到Bar的完整定义.当foo.h包含在另一个文件中(没有看到Bar的定义),VS2010给我这样的警告:warningC4150:deletionofpointertoincompletetype'Bar';nodestr

c++ - 有什么方法可以初始化 unique_ptr 的 vector 吗?

例如structA{vector>m_vector{make_unique(1),make_unique(2)};};我尝试了以上但失败了。有什么方法可以初始化unique_ptr的vector? 最佳答案 您不能从初始化列表中移动,因为元素是const.§8.5.4[dcl.init.list]/p5:Anobjectoftypestd::initializer_listisconstructedfromaninitializerlistasiftheimplementationallocatedanarrayofNelement

c++ - 当我们在 vector 上使用 unique 函数时,移位是如何工作的?

所以,我目前正在阅读一些c++的东西,我在cppreference上看到了这个例子,但我不明白转变是如何工作的。#include#include#includeintmain(){std::vectorv{1,2,2,2,3,3,2,2,1};std::vector::iteratorlast;last=std::unique(v.begin(),v.end());//123213221//^for(std::vector::iteratorit=v.begin();it!=last;++it){std::cout我知道当我们使用unique时它会改变事情,但是我不确定我们如何获得从l

c++ - 将一系列值映射到单个值

我需要将lowerBound和upperBound之间的值映射到某个值。示例:例如,假设我有用户订阅的GPS系统。该系统能够为我提供用户与某个点的距离。根据用户的距离,我想为他们分配一个ID。因此距离远的用户1到100得到ID:8.4101到200得到ID:7.2201到300得到ID:3.6401到600得到ID:4.1等等……我的方法:所以我做了什么,我通过如下初始化创建了一个std::map:std::mapdistanceToIdMap;distanceToIdMap={{100,8.4},{200,7.2},{300,3.6},};然后我使用此代码获取给定距离的ID:doub

c++ - 尝试执行 shared_ptr swap() 时出现奇怪错误

我是一个相对的C++新手,试图将一个现有项目从原始指针转换为使用C++11的shared_ptr.总的来说进展非常顺利,我认为我理解如何shared_ptr在移动语义、右值引用等方面工作。好东西。但是,我遇到了一个奇怪的错误,我不明白也不知道如何修复。先介绍一点背景。我有一个根植于名为EidosValue的抽象基类的类层次结构,和一个名为EidosValue_Int_vector的类是(间接地)一个具体的子类:classEidosValueclassEidosValue_Int:publicEidosValueclassEidosValue_Int_vector:publicEidos

C++ typedef a std::pair 然后使用typedef声明一个映射

假设我有这个typedeftypedefstd::pairMyType;那么,如果我也想使用MyType创建map,我该怎么做呢?我不想重新键入这对中的两种类型,例如:mapmyMap;我想要这样的东西:mapmyMap;有没有办法使用我的typedefMyType而不是重新键入类型来做到这一点? 最佳答案 简单...std::mapmyMap;参见http://en.cppreference.com/w/cpp/utility/pair示例程序位于coliru 关于C++typedef

c++ - clang,返回带有类型转换的 std::unique_ptr

这是我的代码:#includestructA{};structB:A{};std::unique_ptrtest(){autop=std::make_unique();returnp;}intmain(intargc,char**argv){test();return0;}它不会在clang上编译并出现错误:main.cpp:11:12:error:noviableconversionfromreturnedvalueoftype'unique_ptr>'tofunctionreturntype'unique_ptr>'然而,根据this(同样的情况)应该。我是不是误会了什么?我的命令